<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~     http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  -->

<div class="user-access-policies">
    <h2 mat-dialog-title>User Policies</h2>
    <mat-dialog-content>
        <div class="dialog-content flex flex-col justify-between gap-y-3">
            <div class="flex flex-col">
                <div>User</div>
                <div class="tertiary-color font-medium">{{ request.identity }}</div>
            </div>
            <div class="listing-table flex-1 relative">
                <div class="absolute inset-0 overflow-y-auto overflow-x-hidden">
                    <table
                        mat-table
                        [dataSource]="dataSource"
                        matSort
                        matSortDisableClear
                        (matSortChange)="updateSort($event)"
                        [matSortActive]="sort.active"
                        [matSortDirection]="sort.direction">
                        <!-- Policy Column -->
                        <ng-container matColumnDef="policy">
                            <th mat-header-cell *matHeaderCellDef mat-sort-header>Policy</th>
                            <td mat-cell *matCellDef="let item">
                                @if (item.permissions.canRead) {
                                    <div>
                                        {{ formatPolicy(item) }}
                                    </div>
                                } @else {
                                    <div class="unset neutral-color">{{ item.id }}</div>
                                }
                            </td>
                        </ng-container>

                        <!-- Action Column -->
                        <ng-container matColumnDef="action">
                            <th mat-header-cell *matHeaderCellDef mat-sort-header>Action</th>
                            <td mat-cell *matCellDef="let item">
                                {{ item.component.action }}
                            </td>
                        </ng-container>

                        <!-- Actions Column -->
                        <ng-container matColumnDef="actions">
                            <th mat-header-cell *matHeaderCellDef></th>
                            <td mat-cell *matCellDef="let item">
                                <div class="flex items-center justify-end gap-x-2">
                                    @if (canGoToPolicyTarget(item)) {
                                        <button
                                            mat-icon-button
                                            type="button"
                                            [matMenuTriggerFor]="actionMenu"
                                            class="h-16 w-16 flex items-center justify-center icon global-menu">
                                            <i class="fa fa-ellipsis-v"></i>
                                        </button>
                                    }
                                    <mat-menu #actionMenu="matMenu" xPosition="before">
                                        @if (canGoToPolicyTarget(item)) {
                                            <button mat-menu-item [routerLink]="getPolicyTargetLink(item)">
                                                <i class="fa fa-long-arrow-right primary-color mr-2"></i>
                                                Go to
                                            </button>
                                        }
                                    </mat-menu>
                                </div>
                            </td>
                        </ng-container>

                        <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: true"></tr>
                        <tr
                            mat-row
                            *matRowDef="let row; let even = even; columns: displayedColumns"
                            (click)="selectPolicy(row)"
                            [class.selected]="isSelected(row)"
                            [class.even]="even"></tr>
                    </table>
                </div>
            </div>
            <div class="tertiary-color font-medium">
                Some policies may be inherited by descendant components unless explicitly overridden.
            </div>
        </div>
    </mat-dialog-content>
    <mat-dialog-actions align="end">
        <button mat-button mat-dialog-close>Close</button>
    </mat-dialog-actions>
</div>
